<style lang="less">
    @import './login.less';
</style>

<template>
    <div class="login" @keydown.enter="handleSubmit">
        <div class="login-con">
            <Card :bordered="false">
                <p slot="title">
                    <Icon type="log-in"></Icon>
                    欢迎登录
                </p>
                <div class="form-con">
                    <Form ref="loginForm" :model="form" :rules="rules">
                        <FormItem prop="username">
                            <Input v-model="form.username" placeholder="请输入用户名">
                            <span slot="prepend">
                                    <Icon :size="16" type="person"></Icon>
                                </span>
                            </Input>
                        </FormItem>
                        <FormItem prop="password">
                            <Input type="password" v-model="form.password" placeholder="请输入密码">
                            <span slot="prepend">
                                    <Icon :size="14" type="locked"></Icon>
                                </span>
                            </Input>
                        </FormItem>
                        <FormItem>
                            <Button @click="handleSubmit" type="primary" long>登录</Button>
                        </FormItem>
                    </Form>
                </div>
            </Card>
        </div>
    </div>
</template>

<script>
    import Cookies from 'js-cookie';
    import api from '../api';

    export default {
        data () {
            return {
                form: {
                    username: '',
                    password: ''
                },
                rules: {
                    username: [
                        {required: true, message: '账号不能为空', trigger: 'blur'}
                    ],
                    password: [
                        {required: true, message: '密码不能为空', trigger: 'blur'}
                    ]
                }
            };
        },
        methods: {
            handleSubmit () {
                this.$refs.loginForm.validate((valid) => {
                    if (valid) {
                        api.login(this.form).then(data => {
                            if (data.code === 0) {
                                Cookies.set('userId', data.data.id, {expires: 1});
                                Cookies.set('user', data.data.username, {expires: 1});
                                Cookies.set('token', data.data.token, {expires: 1});
                                Cookies.set('access', data.data.roleId, {expires: 1});
                                Cookies.set('accessName', data.data.roleName, {expires: 1});
                                Cookies.set('companyName', data.data.companyName, {expires: 1});
                                Cookies.set('projectId', data.data.projectId, {expires: 1});
                                sessionStorage.setItem('token', data.data.token);

                                this.$store.commit('setMenuList');
                                this.$router.push({
                                    name: 'home_index'
                                });
                            }
                        });
                    }
                });
            }
        }
    };
</script>

<style>

</style>
